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BACKGROUND OF THE INVENTION 



1. 



Field of the Invention 



The present nivehtfon •relatestai- software^ modems,'and more particularly to a software 
modem having a data pump with a plurality of self contained executable modules for updating 



ancfadding drivers to the software modem. 



2. ' Description of the. Related: Art ' ' 




-1- 



WO 00/16534 PCT/US99/21660 

Conventional modems using a telephone line communication channel send data at 
speeds commonly measured in bits per second, or bps. The most common modem speeds are 
28,800 bps, 33,600 bps, and 56,000 bps. However, the actual speed of data moving across a 
telephone line varies and does not always equal the speed that, the modem is capable of 
providing because the telephone line may operate with interference. Thus, to assure data 
integrity, data often travels across a telephone line communication channel at a lower speed than 
is available from the modem. : ' 

Modems have been classified according to various parameters such as potential modem 
speed, data compression techniques, and other communication protocols. Common 
classifications include V.34, for 33.6 kbps modems and V.90, for the 56 kbps modem standard. 

A typical hardware modem operating on a general purpose computer includes a 
controller, a digital signal processor (DSP), a codec (compressor/decompressor), and a digital 
access arrangement (DAA). External hardware modems typically include a universal 
asynchronous receiver-transmitter (UART) while internal hardware modems replace the UART 
with a hardware driver. 

As processing power in general purpose computers has increased through development 

of higher powered microprocessors, modem designers have realized that the computer's 

processor can be used to handle some modem operations. Thus, some functionality performed 

by conventional hardware modems has begun to be implemented in software. As time goes 

one, more and more functionality of hardware modems is being realized in software. However, 

each time that new functionality is converted to software, the new software functionality is 

added to a single software object. Thus, if one part of the functionality is found to be operating 

improperly, the whole software object must be replaced. 

-2- 
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The DSP of a software modem, by nature, performs many different signal processing 
tasks,- e.g., data modulations, fax modulations, etc. In addition, the data pump performs general 
telephonytaskssuch as pulse or tone dialing. These tasks are implemented in a single software 
object and, in operation,; consume a large amount of a computer's memory'- Further, if the 
software modern is to be updated or changed,, the whole object must be replaced. A hardware 
change in one area' of the. modem also, requires- total object replacement even though only a 
small portion of the object is affected. 
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SUMMARY OF THE INVENTION 
Various aspects of the present invention can be found in a communication system 
comprising application software, communication software that interacts with the application 
software, and communication hardware that interacts with the communication software. The 
communication software includ.es at least one controller and a plurality of objects with the 
communication software operating as an interface between the application software and the 
communication hardware. Thus, the. application software comniunicates with the 
communication hardware., The controller. enables the application software to activate one or 
more individual ones of the plurality .of objects to, provide communication between the 
communication system and a communication channel. 

The objects of the .communication system often comprise driver modules having 
individual modem functionality. The at least one controller of the communication system 
enables the -communication software -to operate using a single one of the plurality of objects 
during operation of the communication system. The plurality of objects are individually 
modifiable and individually .replaceable without regarcj to. other ones of the plurality of 
objects and the plurality of objects are often selected from the group consisting of drivers, 
data link libraries, and threads. . . 

Various other, aspects of the present invention are realized in a method for operating a 
software modem on a computer system having a-m ; empry. The method comprises creating a 
plurality of software modules that interact with one. another to perform software modem tasks 
on the -computer .system,- scheduling:: the. plurality of software modem ta^ks according to 
specific operations- of the :soft\vai;e modem,, .Ipadmg ^individual software modules into the 
memory of the computer system on an as needed basis as the software modem operates on the 

-4- 
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e computer system, and unloading individual software modules from the memory of the 
. computer system when the individual software module is no longer required for operation of 
the software modem on the computer system.. 

The method may also comprise modifying individual software modules from the 
plurality of software rrioduies with' trie modifications "occurring independently of software 
10 modules in the : plurality of software rnoclules' that remain unmodified. Modifying individual 
software 'modules may comprise debugging; u^gradfngv or isolating the individual software 
modules,' in some 'dasesfto ' '^ffbSTW'"'di^gfiditics' ; o-n' ! : the'- s6n^are' ! m'bdem ; -independent of the 
remaining software i module's of the so ft ware modem*. 

Further, a software modem according to principles of the present invention may 
15 '" Include 'commun%atibn ;, sVirwa^' W'^ niodem- card. :, The communication software often 
"" includes a 'controller arid a' plurality bf modules; ffie plurality of modules being independent 
from one another and operating ac ; cOrdirig' r tb v instrucTi6M' received from the controller such 
" "that only Wodules specified" by the instructions 1 are -executed in the software modem. The 
"modem"' card often includes aMher''corltrbller; additional -mbdules, and communication 
20 ' hardware! '"''The a'no'thef v contrblWf f -co^ the additional, modules to activate for 

interaction with the communication hardware. <: - h ■ ■ J -- - 

; ? ' ' ' " Trie plurality of moduWof the -sb'ftware' ! mocienvare often modifiable independently 
' ; !f of one another and 'the controller:* In fact, 1 rnoduTes^rhav b© added to the. plurality of modules 
: 'already'' existing In'Vhe com'mlm'fc'auo'ri software of the ; software, modem. In- addition, the 
2 5' " additional' modules of Ine'mo'dem c^a : 'arfr r modi : Ca-^fid-ependently from one another and 
; \he controiler of me mod^ the communication software, the 
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modules of the modem card may be added to the additional modules already existing in the 
modem card of the software modem. 

Other aspects of the present invention can be found in a software modem including a 
plurality of self-contained executable entities. The executable entities include at least^a 
controller and a data pump with the controller operating as an interface between an operating 
system driver and the data pump when signals are passed from the operating system driver to 
the data pump. The data pump includes at least a scheduler and a hardware driver, the 
scheduler interacting with additional self-contained executable entities and enabling the data 
pump to operate using one or more individual ones of the additional self-contained executable 
entities according to the signals passed from the controller to the data pump. 

The self-contained executable entities of the software modem according to the present 
invention often comprise driver modules having individual modem functionality. The 
scheduler enables the data pump to operate using a single one of the additional self-contained 
executable entities during operation of the software modem. The additional self-contained 
executable entities are individually modifiable and individually replaceable without regard to 
other ones of the additional self-contained executable entities. The additional self-contained 
executable entities are commonly selected from the group consisting of drivers, data link 
logic, and threads. 

Still other aspects of the present invention can be found in a software modem that 

includes a controller and a data pump. The data pump may include an abstraction layer, a 

scheduler, a sampler, a hardware driver, and a plurality of modules. The plurality of modules 

are independent from one another and operate according to instructions received from the 

scheduler such that only modules specified by the instructions are executed in the software 
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5 modem. Advantageously, the modules of the software modem are modifiable independently 
of one another and the controller. The modifiable modules comprise modules which enable 
adding additional modules to the plurality of modules already existing in the data pump of the 
software modem. 

Other aspects of the present invention will become apparent with further reference to 
io the drawings and specification. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
A better understanding of the present invention can be obtained when the following 
detailed description of the preferred embodiment is considered in conjunction with the 
following drawings. • 

Figure 1 is a block diagram of an exemplary communication system built in 
accordance with the principles of the present invention wherein, as illustrated, the 
communication system communicates with a communication channel via application 
software, communication software, and communication hardware. 

Figure 2 is a block diagram of the communication system of Figure : 1 wherein the 
communication hardware of Figure 1 is illustrated as being part of a modem card. 

Figure 3 is a block diagram of portions of- the communication system of. Figure 1 
wherein' the application software' and communication hardware are -illustrated having multiple 
components. * \ : 

Figure 4 is a block diagram of an exemplary computer system built in accordance with 
the principles of the present invention wherein the computer system is illustrated interacting 
with a telephone line via components such as a software modem. 

Figure 5 is a block, diagram : of the software? modem of Figure 4 illustrated in greater 
detail than in Figure 4. ' , . 

Figure 6 is a block" diagram of exempiary self-cbntairied signal processing tasks or 
driver modules that operate in conjunction with 'the software modem 6f Figure 4. ; 



# 

WO 00/1 6534 PCT/US99/21660 

5 DETAILED DESCRIPTION OF DRAWINGS 

' ■ Fiaure 1 is a block diagram of an exemplary communication system 100 built in 
■accordance with the principles of the, present invention wherein, as illustrated, the 
communication system 100 communicates with a communication channel 102 via application 
software 104, communication software 106, and communication hardware 108. In one 

10 embodiment, a user controls the application software 104 in order to operate the 
communication system 100. The application software 104 interacts with the communication 
software 106 and prompts a controller 110 to determine which object(s) 112 to activate in 
order to operate the communication hardware 108 and carry out communications through the 

'"' ; '•c : 6mrnUni^ati'ohcfianhel-l'02^ :.-.-.r, : : . ..••<• 

15 The object(s) 1 12 are interchangeable, modifiable, updateable, upgradeable, and may 

increase in hu'iilber or in size. -Worn -embodiment, one .object ,112 . can interact with the 
* 'application* 'software 104^and ^ctivate.:othier: objeets:;ai2' to provide interaction with the 
communication hardware 108. Another embodiment provides multiple objects 1 12 to interact 
with the application software 104 and, together, activate a single object 112 for interaction 

2.0. with the. communication hardware 108. Yet another embodiment provides for multiple 
objects 112 to interact with the application software 104 and then, in turn, to interact with 
multiple object 112 for interaction with the communication hardware 108. Advantageously, 
indivWuai objWt(s) M l2 ; c other- object(s) 112. The 

object(s) 112 also enable the communication system 100 to operate using only the required 

2 5 , - o£jsct<s).-U 2 .for .the .revested function in the communication system 100. Further, only the 
required ^pbjeqt^s,) 1)2,.. are activated . or accessed depending on requirements from the 
communication hardware 108. Thus, the communication system 100 enables multi-task plug- 
in objects and operates more efficiently than prior art communication systems. 

-9- 
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Figure 2 is a block diagram of the communication system 100 of Figure 1 wherein the 
communication hardware 108 is illustrated as being pan of a modem card 200. The modem 
card 200 includes the communication hardware 1 OS and a controller 202 that controls 
object(s) 204 and activates specific ones of the objcct(s) 204 on the modem card 200 
according to desired operations of the communications system 100. Like the communication 
system 100 of Figure 1, bbject(s) 204 interact either directly or indirectly with the 
communication hardware 108 as instructed by the controller 202.. Communication software 
205 having a controller 206 is illustrated' for controlling objcct(s) 208 as . they interact with 
application software 210 and the modem card 200. The objects 204 and 208 interact as 
directed by the controllers 202 and 206, respectively, and create, the interface between the 
communication software 205 and the modem card 200. 

Figure 3 is a block diagram of portions of the. communication system of Figure 1 
wherein the application software l'04 ;; -and : cbmmunication hardware- 108 are , illustrated as 
having multiple components. Specifically, in this-embo : diment,.the application software 104 
comprises a plurality of software applications 300 for user .access to. the communication 
software 106. Particular software applications 300 direct the communication software 106 in 
particular manners:' For example, the controller 1 10 is directed to activate one of. the objects 
112 which in turn activates another of the objects 112 which in turn- interacts with , a portion 
302 of the. communication hardware 108. The portion 302 of the communication hardware 
108 then interacts with another portion 302 which in turn interacts with the communication 
channel 102. , Of course, other variations and combinations of the process of the application 
software 104 interacting with the communication channel 102 are possible and the above 
example is offered only for illustrative purposes. 

-10- 
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Figure 4 is a block diagram of an exemplary computer system 400 built in accordance 
with the principles of the present invention wherein the computer system 400 is illustrated 
interacting with a telephone line 402 via components such as. a software modem 404. An 
application 406 accesses the . software modem, 404 through an operating system 
tornrnuhication- driver ■•40&-and the software modem 404 accesses the telephone line 402 
through a -hardware interface 410; The .application 406 is a standard modem application for a 
user ; t6 operate a modem on. the, computer system. 400, The^operating system communication 

driver : 408< is-;a .^ 410 W ically 

comprises a. : codec and : a BAA and provides .a rr path for the software modem 404 to 
communicate jWitb the - telephone line 4Q2, r(i -.- ;, . .;. j 

Figure 5 is a block diagram of the software modem 404 illustrated in greater detail 
Mh^n 'in-Tigure 4,; The software : modem ,404. is, illustrated ..haying a plurality of modules 
including* port driver .500,* -co.ntro.Ues -Wh a, data : p wip_ abstraction layer (DPAL) 504, an 
advanced modem operation scheduler ,( AMOS), 5 ; Q6, a .sampler .508, and a hardware driver 
510. Further- the software modem 404 includes : a ; plurality of. driver modules 512 that interact 
With'ffie- othenaxxSuinua 4he soJwe.-mpa^rn 404,. Collectively, the modules between the 
- 1 ■cehtrbHer;502>and the;hardware interface, 51.0 are often referred to as the "data pump" of the 
: s6irw ; aTe'modem=4<34.' .;. ; . . , : ■,• ; ; . . •• :, .-./Ik-sc. - • .- 

' " Of particular note, the plurality 1 of modules of the 1 software modem 404 have been 
divided into individual tasks rather than being combmed into 1 a single object as in the related 
art. Specificaily.Tn one embodiment^ne data pump' im^emerits the scheduler (AMOS) 506 
to select only the appropriate '' driver ' modules 51 f 5 for ' thV ; requested 'modem task. For 
pie, modems commonly provide both data arid fax capabilities, and data modulations are 
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not needed for fax sessions. Thus, the scheduler 506 of the data pump loads only the driver 
modules 512 for data modulation during data modulation operations. Likewise, if the modem 
404 is to operate as a speaker phone, the scheduler 506 will load only the speaker phone 
module into memory. Similarly, each modem task that can be performed with an individual 
driver module is typically implemented as one of the driver modules 512 and the scheduler 
506 loads the required driver module(s) into memory of the computer exclusive of the other 
driver modules that are not required. 

Figure 6 is a block diagram of exemplary self-contained signal processing tasks or 
driver modules that operate in conjunction with the software modem 404. As illustrated, the 
driver modules 600 could include at least the following drivers, a V, 90 driver 602, a K56Flex 
modem driver 604, a fax. driver 606, a tone generator driver 608, a speaker phone driver 610, 
or other type of driver 612. The V.90 driver 602 represents the 56.0 kbps modem standard 
adopted by the modem Standards Committee. Similarly, the K56Flex modem driver 604 is a 
modem driver used by some modem manufacturers. Of course, the fax driver 606 represents 
a driver to be used for facsimile transmission, the tone generator driver 608 represents the 
driver for producing modem tones during modem 404 operatioii; the speaker phone driver 
610 provides speaker phone capability for the modem 404, ant as represented by the dotted 
lines of the other type of driver 612, numerous additional types of driver modules can be 
included to operate the modem 404 with the scheduler 506. 

The multiple driver. software modem 404 provides a software data pump in which 
each driver is a, separate .self contained object such as a driver, a data link library (DLL), a 
thread etc The scheduler 506 decides which driver should be loaded into computer memory, 
which driver should be activated, and what samples (if any) should be streamed to/from each 

-12- 
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5 of the drivers to the hardware interface 410. Dividing these tasks into separate drivers 
provides for efficient usage of computer memory because drivers can be loaded into memory 
only as needed for each particular session and unloaded in accordance with the session 
progress. ' * . . ■ . , 

Since different drivers are loosely coupled, whenever a driver is modified, the other 
drivers that do not involve the modified driver do not need to be tested as would be required 
in a single object data pump. In particular, fixing a Bug in a driver only requires replacement 
of a single driver jandcthe, rest, of th e software .modem remains ; unchanged. These advantages 
also apply in the development stage, e.g^a^new,. driver may .be, replaced without modifying 
•the^resf of the'tnodem and each driver-can be more easily .isolated and developed separately. 
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1S In operation, a typical modem' tisk is a modulation, such as V.90, V34, a tone 

detector, or any other 'task such as a pulse' dialer:' Individual modules are available for each of 
these tasks." Another module could i be implemented in which' all the hardware accesses are 
contained ina single module thereby providing an abstract interface to other modules. 



.. : ,. ; r The ,aboye.-listed section^ and included information are not exhaustive and are only 
; ^empla^ r /o.r ; ,cp,rn.pu4e;. systems.. The particular^ sections and included information in a 
p^ici|lar, embodiment ,may. depend uoon toe particular implementation and the included 
devices and resources. Although a system and method according to the present invention has 
been described in connection with the preferred embodiment, it is not intended to be limited 
to the specific form "set forth' herein, ! but' bh m'e'-'cbn'trary; ! it -is intended to cover such 

alternatives, modifications^ and equivalents; as" can :; bV reasohably-irieluded within the spirit 

;! Ovarii v><.: b'si!\.Ai :S; H-i.-hv -:> t -*ii'"ij ,-j'V • •., >■■■.■ ■ . ■ ~ • • . 

and scope of the invention as defined by the appended claims. ■ ■ - - 

-13- 
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CLAIMS 

1 . A communication system comprising: 
application software; 

communication software that interacts with the application software; ^ 

communication hardware that interacts with the communication software; 

the communication software including at least one controller and a plurality of 
objects, the communication software operating as an interface between the application 
software and the communication hardware such that the application software communicates 
with the communication hardware; and 

the at least one controller enabling the application software to activate one or more 
individual ones of the plurality of objects to provide communication between the 
communication system and a communication 1 channel. ' :h 

2. The communication system of claim 1 wherein the plurality of objects comprise driver 
modules having individual modem functionality. 

3. The communication system of claim 1 wherein the at least one controller enables the 
communication software to operate using a single one of the plurality of objects during 
operation of the communication system. 

4. The communication system of claim 1 wherein the plurality of objects are 
individually modifiable and individually "replac'eable without regard -to other ones of the 
plurality of objects. . . — 

5. The communication system of claim 1 wherein the plurality of objects are selected 
from the group consisting of drivers, data link libraries, and threads. 

-14- 
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6. A method for operating a software modem on a computer system having a memory, 
the method comprising: 

creating a plurality of software modules that interact with one another to perform 
software modem tasks on the computer system; 

scheduling the plurality of software modem tasks according to specific operations of 

the software modem; 

loading individual software modules into the memory of the computer system on an as 
needed basis as the software modem operates on the computer system; and 

unloading individual software modules from the memory of the computer system 
when the individual software module is no longer required for operation of the software 
modem on the computer system. 



7. The method of claim 6 further comprising ^odifying individual software modules 
from the plurality of software modules, the modifications occurring independently of 
remaining software modules in the plurality of software modules. 

8. The method of claim 7 wherein the step of modifying individual software modules 
comprises debugging the individual software module. 

9. The method of claim 7 wherein the step, of modifying individual software modules 
comprises upgrading the individual software module. 



10., o : ^he method of elajjp.7 whpreifl th? rte£ of mpdi^ng individual software modules 
comprises isolating the individual software module to perform diagnostics on the software 
modem independent of remaining software modules of the software modem. 



IV/ 
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11. A software modem comprising: 
communication software and a modem card; 

the communication software including a controller and a plurality of modules, the 
plurality of modules being independent from one another and operating according to 
instructions received from the controller such that only modules specified by the instructions 
are executed in the software modem; and 

the modem card including another controller, additional modules, and communication 
hardware, the another controller controlling which of the additional modules to activate for 
interaction with the communication hardware. ^ 

12. The software modem of claim 1 1 wherein the plurality of modules are modifiable 
independently of one another and the controller: l J . 1 

13. The software modem of claim 12 wherein modules may be added to the plurality of 
modules. already existingin the communication software of the software modem. 

14. The software modem of claim 11 wherein 1 the additional modules of the modem card 
are modifiable independently from one another and the another controller: 

15. The software modem of claim 14 wherein modules may be added to the additional 
modules already existing in the modem card of the software modem. £ 
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